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(57) Abstract: An online machine data collection 
and archiving process (15) generates a machine data 
profile (18) of a customer computer (5) accessing a 
transaction form of a merchant web site (3) and links the 
machine data profile (18) and a transaction record (6) 
with customer identifying information using a unique 
transaction identification string.: The process preferably 
captures parameters typically communicated as part of 
web accesses, such as an IP address, an HTTP header, 
and cookie information. The process additionally causes 
the customer computer (5) to process self-identification 
routines by processing coding within the merchant 
transaction form, the self-identification routines 
yielding further profile parameters. The process further 
includes a routine for bypassing au intervening proxy 
to the merchant web site (3) to reveal the true IP address 
of the customer computer (5). 
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ONLINE MACHINE DATA COLLECTION AND ARCHIVING PROCESS 



3 Cross-Reference to Provisional Application 

4 This application claims benefits from provisional application, Serial No. 

5 60/209,936 filed June 7, 2000 and entitled METHOD FOR COLLECTING MACHINE 

6 DATA FROM CUSTOMERS ON A COMPUTER NETWORK. 



8 Background of the Invention 

9 The present invention relates to identity detection techniques and, more 

1 0 particularly, to a process for collecting and utilizing machine-identifying data of computers 

1 1 and other online appliances used in online interactions and transactions and associating the 

1 2 collected machine data with such online interactions. 

1 3 The internet, or global computer network, represents a new medium for marketing 

* 

1 4 similar to the way mail ordering and telephone ordering did in the past. A downside of 

1 5 internet marketing is that it also presents new opportunities for unscrupulous persons to 

1 6 take advantage of the mechanisms of internet transactions by fraudulent and deceptive 

1 7 practices. Merchants and financial institutions bear the initial costs of fraud. However, 

1 8 consumers ultimately pay the costs in the form of prices and credit rates which must take 

1 9 into account losses from fraud. Internet purchases typically involve the use of web page 
2 0 forms which are filled in by the customer with identity, address, purchase, shipping, and 
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1 payment information and submitted to the online merchant for processing. Internet 

2 purchases are most often paid for by way of credit cards. While a merchants software 

3 may be able to verify the existence and status of a credit card account number and an 

4 authorization for a specific amount, the merchant is often not able to match a credit card 

5 number with a specific purchaser or shipping address. Thus, absent any overt indication 

6 otherwise, a merchant generally assumes that anyone using a credit card is authorized to 

7 do so and that a customer is who he identifies himself to be. 

8 An important step in combating fraud is accurate identification of the computers 

9 through which customers make transactions and associating such identities with 

1 0 transactions which arouse suspicions or which ultimately turn out to be fraudulent. Basic 

1 1 machine identity is essential to the manner in which the internet operates. We speak in 
1Z terms of "going? to a web site. In reality, "going" to a web site involves sending a request 

13 for a web page file in a directory or folder on a computer located at a specific internet 

1 4 protocol, or IP, address. In order for the web page file to be returned to the requesting 

1 5 computer for processing into a displayed "web page", the request must include return 

1 6 "directions" in the form of the basic identity of the requesting computer, including its IP 

1 7 address. Some web sites are implemented with software which enables responses to web 

1 8 page requests to be tailored to specifics of the requesting machine's configuration, specific 

1 9 web browser, and the like. For this reason, current versions of browsers usually 

2 0 communicate configuration information in addition to a return IP address and return path. 
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1 The IP address of a page requesting computer can give an indication of the specific 

2 country where the computer is located. Further, identification of a page-requesting 

3 computer can also recognize a returning user using the same computer as during a 

4 previous access. For example, placing an HTTP (hypertext transfer protocol) "cookie" on 

5 a page-requesting computer can make it possible to identify the computer on a later 



access. 



7 Because direct interaction with a customer's computer is essential in detecting 

8 fraud, it has been assumed that any viable fraud detection software must be integrated with 

9 a merchant's software. As a result, most existing fraud detection solutions require 

1 0 merchants to either abandon or extensively modify their existing web-based transaction 

1 1 processing software. An additional problem with focusing fraud detection at single 

1 2 merchants is that perpetrators of fraud often hit many merchants in an attempt to avoid or 

13 delay detection. Thus, an ideal system for fraud detection in online marketing would only ' 

1 4 minimally affect the merchant's existing software and would route fraud detection efforts 

1 5 through a central, third-party entity serving a large multitude of merchants. 
16 

17 Summary of the Invention 

1 8 The present invention provides a process for collecting data associated with a 

1 9 customer's computer during access of a merchant, financial, other host web site, and 

2 0 associating a transaction identification number with the data and with a transaction form of 

2 1 the merchant. Generally, the present invention captures machine identifying data from a 
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1 computer or other digital appliance accessing a host web site, sends the captured data to a 

2 machine data archive along with a unique transaction identification string for storage in the 

3 archive and writes the same transaction identification string into a transaction form 

4 through which transactions with the host web site are conducted. The machine data is, 

5 thus, associated with the customer identification data within the transaction form by way 

6 of the transaction identification string and can be used on-the-fly or at a later time for a 

7 variety of purposes including, but not limited to, fraud detection. Although the terni 

8 "archive" is used, the machine data collected need not be stored permanently. 

9 The machine data collection process of the present invention is intended to be 

1 0 employed in a variety of applications including, but not limited to: online purchases and 

1 1 orders; online banking, bill payment, and funds transfers; online registrations, such as for 

1 2 memberships, product warranties, applications for credit, renewal of subscriptions and 

1 3 licenses; online technical support; and the like. The term "transaction" is used in the 

1 4 present invention to describe an interaction effected between a digital appliance and a host 

1 5 system. However, the term "transaction" is not intended to be restricted to only 

1 6 commercial interactions involving purchases. The term "transaction" is intended to apply 

17 to an interaction of a remote digital appliance with a host system using a relatively 

1 8 anonymous type of access process over a digital medium in which some form of self- 

1 9 identification of the accessing appliance is inherent in the access process and in which the 

20 true identity of the accessing party, the true source address of the appliance on the 

4 
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1 medium, and/or the true machine characteristics of the accessing appliance is/are essential 

2 or desirable to the interaction. 

■ 

* 

* 

3 The host entity which operates the host system accessed is intended to encompass 

4 a commercial, financial, educational, governmental, associational, or other type of entity. 

5 The terra "merchant" will be used herein to refer to such a host entity without intent to 

6 limit the present invention to commercial transactions. The medium of access is intended 

* 

7 to be interpreted as including a global computer network such as the internet or world 

8 wide web, as well as other types of networks which may be less than global but which are 

9 publicly and/or anonymously accessible. The term "internet" will be used herein to refer 

10 to the medium through which accesses to the host entity are made. The terms "customer 

1 1 computer" or "machine" are used herein to refer to a device for effecting remote access to 

12 a host system over a digital medium and are meant to encompass not only conventional 

1 3 types of personal computers, but also additional types of "digital appliances" with online 

1 4 access capabilities, such as: cell phones, personal digital assistant devices, electronic game 

1 5 systems, television sets with online access capabilities, web appliances for vehicles, and 

16 any other type of device with online access capabilities whether connected to a wired 

1 7 communications network directly or by a radiant technology. 

1 8 The machine data collection process of the present invention contemplates a two 

1 9 party process embodiment in which a "merchant" processes and/or stores machine data 
2 0 profiles of customer computers in-house, as well as a three party process embodiment in 



5 



WO 01/97134 



PCT/US01/18076 



which machine data profiles of customer computers are processed and/or stored for the 
merchant by a third-party machine data collection and archive service. 

In a two party embodiment of the data collection process of the present invention, 
the customer machine data is captured by a merchant or host system which also generates 
a unique transaction identification (ID) string and assigns or associates the transaction ID 
with a machine data profile of the customer machine data profile. In the two party 

m 

process, the merchant system captures customer computer data which is inherently passed 
from the customer computer to the merchant's web site, such as an IP address of the 
customer computer and an HTTP header. Additionally, according to the present 
invention, the merchant web page code may have routines or calls for external routines 
which, when processed by the customer computer, cause the customer computer to 
further identify itself by collecting and returning certain machine and software 
configuration characteristics, which can be used to identify the particular customer 
computer. The two party process may include the generation and setting of an HTTP 
cookie in the customer browser for recognition upon a later access with the merchant web 
site. 

Although the two-party embodiment of the machine data collection process of the 

► 

present invention has utility for some applications, the three party embodiment is preferred 
for applications in which analysis of a maximum number of customer computer profiles is 
desirable, such as certain types of marketing processes and fraud detection and control 
processes. In a three embodiment of the present invention, the customer machine data of 
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computers accessing the second party or merchant web site is communicated to and stored 
within a third party system, referred to herein as a machine data archive service. In the 
three party process, the transaction ID could be generated by the merchant system, but is 
preferably generated by the archive service. The use of the term "archive" is not meant to 
indicate that the customer machine data profiles are stored permanently within the third 
party system. Permanent storage of such profiles may not be practical, as far as yielding 
beneficial results to the purposes for which the profiles are collected. Thus, the term 
"archive" is meant to indicate a central storage facility, such as a database, with a selected 
retention period, with purging of most profiles after a certain length of time. 

In the three party process a routine or line of code is added into the hypertext 
markup language (HTML) code which defines the merchant's web page, particularly an 
order or transaction form page. The added routine issues a request for a machine data 
collection (MDC) script to the third-party web site when the form page code is processed 
by the customer's browser. When the script request is received by the machine data 
archiving service (MDAS), the archive service generates a unique transaction 
identification (TA/DD) and checks ft>r its own cookie. If no MDAS cookie is present, the 
archive service sends a cookie to the requesting computer along with a machine data 
collection (MDC) script having the transaction ID embedded therein. The MDC script is 
executed by the customer's browser, causing collection of certain data from the 
customer's computer which is sent back to the archive service along with the transaction 
ID and stored in a machine data profile in the machine data archive. The transaction ID is 
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written into the transaction form, and when the transaction form is submitted to the 
merchant web site, the transaction ID string becomes a part of the transaction data record, 
along with customer identification, location, and financial information. 

The machine data initially collected and stored in each profile preferably includes 
the transaction ID, the apparent IP address of the customer's computer, a conventional 
HTTP header which identifies the customer's browser versions and certain configuration 

m 

aspects of the browser, and the archive service's cookie. The combination of such 
information, minus the transaction ID, will be relatively rare but may not be unique. 
Additionally, customers intent on conducting fraudulent transactions often hide their IP 
address behind HTTP proxies. In order to further narrow the machine profile, in a 
preferred embodiment of the present invention, the MDC script performs additional 
machine profiling operations: generation of a machine "fingerprint" and a proxy 
"piercing" operation. 

In the fingerprint generation operation, the MDC script assembles an attribute 
string formed by various attributes or configuration settings of the browser which can be 
queried by the script. The MDC script then performs a conversion process on the 
attribute string to generate a fingerprint string having content which is a function of the 
original content of the attribute string. The conversion process is preferably a "hashing" 
function which is, in effect, an irreversible encryption algorithm. The generation of a 
conventional checksum is one example of a type of hashing function. For example, if the 
attribute string is formed by alphanumeric characters, the conversion process is performed 

8 
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on the string of codes representing the characters. The particular conversion process or 
hashing function used may be one of many types of conventional conversion algorithms or 

• ■ 

hashing functions, which are typically used for data integrity tests. The resulting string 
from the MDC conversion process is a so-called fingerprint, which is returned to the 

archive service along with the transaction ID for storage in the machine profile. A time 

» 

value, queried from the customer computer time-of-day clock, is returned with the 
fingerprint string and stored in conjunction therewith. 

An HTTP proxy is one of several types of proxies through which a browser may 
be setup to operate. Setting up an HTTP proxy causes HTTP requests to be relayed by a 
primary gateway, through which the computer actually interfaces to the internet, to a 
remote secondary gateway, or proxy, with an IP address different from the primary 
gateway IP address. Such redirection hides the true IP address of a computer. The proxy 

-r _ 

piercing operation of the MDC sbript queries the customer computer for any LAN (local 
area network) address which may be assigned to the computer and reads the system time 
of day clock. Then attempts are made to send the LAN address, if any, the time value, 
and the transaction ID to the archive service using a protocol which will not be redirected 
through the HTTP proxy, for example a lower level protocol such as TCP/IPor UDP 
protocols. If the attempt is successful, the message containing the time value, the 
transaction ID, and LAN address arrive at the archive service web site with the true return 
IP address of the customer computer, whether an HTTP proxy intervenes or not. The 
LAN address and IP address so derived are stored in the machine profile. It should be 
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noted that the use of an HTTP proxy is not, of itself, an indication of fraud. However the 

acquisition of an additional IP address is one more parameter with which to identify a 

- 

particular computer. 

When, and if, the customer submits the transaction form to the merchant, the 

•j 

transaction ID string is communicated to the merchant, along with other customer 
information such as name, address, credit card number and the like plus transaction 

* 

information. The complete transaction record is stored on the merchant's system and is 
associated with a specific machine identity profile within the archive service by way of the 
transaction ID string. Thereafter, the stored machine identity profiles and transaction 
records of large numbers of transactions can be analyzed by various ftaud detection 
techniques to detect patterns of fraud and fraud attempts and, preferably, identify and 
locate the sources of such activity. 

The machine data profiles stored in the archive service need not be combined with 
the customer identification information for non-suspicious transactions, to thereby 
preserve the privacy of non-suspicious customers within the machine data archive. 
However, the processes of the present invention do not require that the customer 
identification information be kept separated from any associated machine data profiles, and 
there may be reasons to combine the associated records. 
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1 Brief Description of the Drawing s 

2 Fig. 1 is a simplified block diagram illustrating a plurality of customer and 

3 merchant computers interfaced to the internet along with a machine data archiving service 

4 computer for practicing the machine data collection process of the present invention. 

5 Fig. 2 is a simplified block diagram illustrating connection of a customer computer 

6 to the internet, with optional components shown in phantom lines. 

« 

7 Fig. 3 is a flow diagram illustrating principal steps of the machine data collection 

8 and archiving process according to the present invention. 

9 Fig. 4 is a flow diagram illustrating more detailed steps of the machine data 

1 0 collection and archiving process according to the present invention. 

1 1 Fig. 5 is a flow diagram illustrating a still further detailed steps in the machine data 

1 2 collection and archiving process of the present invention. 

1 3- Various objects and advantages of this invention will become apparent from the 

1 4 following description taken in relation to the accompanying drawings wherein are set 

1 5 forth, by way of illustration and example, certain embodiments of this invention. 

16 The drawings constitute a part of this specification, include exemplary 

1 7 embodiments of the present invention, and illustrate various objects and features thereof. 
18 

19 



11 



■ 



WO 01/97134 PCT/US01/18076 



1 Detailed Description of the Invention 

2 As required, detailed embodiments of the present invention are disclosed herein; 

3 however, it is to be understood that the disclosed embodiments are merely exemplary of 

4 the invention, which may be embodied in various forms. Therefore, specific structural and 

5 functional details disclosed herein are not to be interpreted as limiting, but merely as a 

6 basis for the claims and as a representative basis for teaching one skilled in the art to 

7 variously employ the present invention in virtually any appropriately detailed structure. 

w 

8 Referring to the drawings in more detail: 

9 The reference numeral 1 (Fig. 3) generally designates 

10 a process for online collection of machine identifying or profiling data of computers 

1 1 involved in commercial transactions and for archiving such data to facilitate analysis for 

1 2 fraud detection purposes. The process collects machine identifying or profiling data of 

1 3 computers involved in commercial transactions and archives such data in a third-party 

1 4 machine data archive service in association with a transaction identification string or ID 

1 5 which is also written into a transaction form of a merchant with whom the customer is 

1 6 conducting a transaction. 

1 7 Fig. 1 illustrates a plurality of host entities or merchants with corresponding 

1 8 merchant computers 2, on which are operated merchant web sites 3 which are accessible 

1 9 over a global computer network, such as the internet 4, by a plurality of customer 

2 0 computers 5 . The merchant computers 2 execute various programs which enable the sale 

21 of products or services by way of the internet 4. The merchant web sites 3 typically make 
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use of form type web pages with which the customers 5 interact by filling in various data 
fields, for example, name, address, shipping address, telephone number, credit card type 
and number and expiration date, and description and quantities of products to be ordered 
The merchant transaction forms are usually written in hypertext markup language 
(HTML) and may include requests for code written in other languages, such as Java and 

1 * 

the like. When a customer 5 accesses a merchant's transaction form, a transaction form 
file is communicated to the customer's computer with various data fields displayed as fill- 
in boxes or the like. The customer fills in the appropriate fields and selects a submit 
"button" which activates a routine to transfer the collected information back to the 
merchant web site 3 for processing. The returned "form" is a data record 6 which is 
stored in a merchant transaction database 7 for retrieval and processing in due course to 
cause the ordered items to be gathered, packaged and prepared for shipment, along with 
financial processing to debit the customer's credit account. The financial processing may 
include a validity check of the credit account and an authorization check for the amount of 
purchase with the credit card issuer. Additionally, inventory management processes are 
executed based on the items withdrawn from stock for shipment. 

In a three party embodiment of the present invention, the process 1 makes use of 
an entity referred to herein as a machine data archiving service, MDAS or archive service, 
which operates an archive service computer system 15, including an archive service web 
site 16. The archive service system 15 maintains a machine data archive service database 
or archive 17 in which the machine data collection profiles 18 from customer computers 5 

* 

13 
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1 of the merchants 2 are stored. The archive service web site 1 6 is interfaced to the internet 

2 4. The archive service 15 is preferably independent of the merchants and may be operated 

3 by a merchants' association, a financial institution or association thereof, or may be an 

4 independent contractor. Alternatively, H is conceivable that a merchant with a high 

5 volume of online sales could operate its own in-house machine data profile collection and 

6 archiving service 1 5, for fraud detection or possibly for marketing purposes. 

7 Referring to Kg. 2, a customer computer system 5 includes a customer computer 

8 20 interfaced to the internet 4 by way of a primary gateway 22, as of an internet service 

9 provider (ISP). The computer 20 might be one of many on a local area network or LAN 

10 24 which includes a router or switch which routes data from the internet 4 to the 

1 1 computers on the network. The computer 20 may communicate through the internet 4 by 

1 2 way of a HTTP (hypertext transfer protocol) proxy 26, which disguises the internet 

1 3 protocol (IP) address of the actual gateway 22. The computer 20 accesses web sites on 

14 the internet 4 using a customer web browser 28 which processes HTML language and 

1 5 various other standard web oriented languages to display or otherwise render the content 

1 6 of web pages and interact therewith. The browser 28 is normally enabled to accept 

> 

1 7 "cookies" 30 which are stored in a cookie file. Cookies 30 are data strings which are 

18 issued by web sites and give an indication of a previous visit to a particular web site and 

1 9 may indicate a particular configuration or set of preferences of the customer's setup of the 
2 0 computer 20. Typically, the customer computer 20 has a time of day clock/calendar 32. 
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1 The customer computer 20 may have a fixed IP address, depending on the manner 

2 in which it is interfaced to the internet. More commonly, the customer computer 20 will 

3 have a temporary or dynamically assigned IP address which is determined by the primary 

4 router 22. The primary router 22 has an IP address, as do a router of a LAN 24 or an 

5 HTTP proxy 26 if either is present in the customer's computer system 5 . 

6 Fig. 3 illustrates the principal actions or steps of a general or basic process 34 of 

7 the process 1 for collecting machine identifying data from customer computers 5. At step 

8 35, at least one machine identifying profile parameter is captured upon access of a 

9 customer computer 5 or other online access device with a host or merchant web site 3. A 

1 0 unique transaction identifier or TA/ED is generated at 36 and associated at 37 with the 

1 1 captured profile parameter. The transaction ID is also associated at step 38 with a 

1 2 transaction record generated as a result of the interaction or transaction conducted 

1 3 between the customer computer 5 and a merchant web site 3 . Although not specifically 

1 4 shown in Fig. 3, the process 34 may capture machine profile data that is passed from the 

1 5 customer computer 5 to the merchant computer 3 as an inherent step of the customer 

1 6 computer 5 accessing the merchant computer 3. Alternatively, the process 34 may pass 

1 7 routines to the customer computer 5 to cause it to "self-identify" itself by querying certain 

1 8 configuration parameters and passing such information to a machine profile stored either 

19 within the merchant's system 2 or in a third party archive 17. The process 34, thus, 

2 0 encompasses a two-party embodiment or a three party embodiment of the machine data 

2 1 collection and archiving process 1 of the present invention. 
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Referring particularly to Fig. 4, a more particular three party embodiment of the 

» 

machine data collection and archiving process 1 begins at step 40 with the coding of a 
machine data collection (MDC) script request into the web page code for a transaction 
form of a merchant web site 3. When a customer 5 accesses the merchant transaction 
form at step 42, the customer browser 28 processes the transaction page code, including 
the MDC script request, which causes the MDC script request to be communicated to the 
archive service web site 16 at step 44. The script request arrives at the archive service 15 
with a set of customer machine parameters which principally provide a return path for the 
MDC script from the archive service 15 to the customer 5. The customer machine 
parameter set preferably includes "user agent" information, which is the version of the 
customer browser 28. 

At step 46, the archive service 15 generates a unique transaction ID string and 
associates it with the customer machine parameter set in the MDAS archive 17. At step 
48, the archive service returns the MDC script, with the transaction ID embedded within 
it, to the customer browser 28. At step 50, the customer browser 28 processes the MDC 
script which, at a minimum, writes the transaction ID string into the merchant's transaction 
form. Assuming that the customer 5 completes the transaction and submits the transaction 
form to the merchant 2 at step 52, the transaction ID string is stored with the transaction 
data record 6 in the merchant transaction database 7. The transaction ID, thus, indirectly 
associates the machine data parameter set 18 stored in the MDAS archive 17 at step 54 
with the customer identity information stored with the transaction data record 6 in the 

16 
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merchant's transaction database 7. Thereafter, qualified parties may access the MDAS 
archive 17 for information related to a transaction ID. 

The MDAS archive 17 need not contain any information which specifically 
identifies a particular customer, only the machine parameter profiles 18 with associated 

r ■ 

transaction ID strings. The MDAS archive records 18 can be analyzed in conjunction with 
the merchant transaction records for patterns of fraud or for other purposes. The great 
majority of MDAS archive records can be purged from the archive 17 after a selected 
period of time. Any records which are associated with any transaction irregularities or 
suspicions of actual fraud may be retained longer. 

Fig. 5 illustrates the principal steps of a preferred embodiment 60 of the machine 
data collection and archiving process 1 of the present invention. The process 60 begins 
with the addition at 62 of a machine data collection (MDC) script to the transaction (TA) 
form page code of a merchant web site 3. The transaction form page code is processed at 
64 by a customer browser 28 when the rfierchant web page is accessed to thereby request 
the MDC script at 66 from the Machine data archive service (MDAS) web site 16. When 
the browser 28 accesses the MDAS web site 16, requesting the MDC script, the MDAS 
web site checks for the presence of an MDAS cookie at step 68. If no MDAS cookie is 
detected, an MDAS cookie is generated at 70 and a unique transaction identification 
(TA/ID) string is generated at 72. The MDC script, transaction ID, and cookie, if not 
previously set, are returned at 74 to the customer browser 28, the transaction ID being 
embedded within the MDC script. 

17 
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1 When the MDC script is received by the browser 28, it is executed at 76. The 

2 cookie is stored in the cookie file 30, or possibly in the memory of the customer computer 

3 20. Execution of a preferred MDC script causes several actions to be performed. The 

4 MDC script writes the transaction ID into the transaction form at step 78. The script can 

5 do this by either setting an existing variable of an appropriate name to the transaction ID 

6 string or by writing an appropriate variable into the transaction form page and setting its 

7 value to the transaction ID string. Additionally, the preferred MDC script generates a 

8 "fingerprint" of the customer computer 20 at step 80 and attempts to perform a proxy 

9 piercing operation at step 82. 

1 0 In generating the machine fingerprint at 80, the MDC script queries the browser 28 

11 for a number of attributes and settings and concatenates the results into an attribute string 

12 at 84. The MDC script then performs a hashing algorithm on the attribute string at 80 to 

1 3 generate a fingerprint string which has a high degree of uniqueness. Hashing functions are 

1 4 irreversible encryption processes in which the result is dependent on the original content of 

1 5 the data on which the hashing algorithm is operated. Hashing functions are commonly 

1 6 used for data integrity checking. As previously stated, a common checksum is the result 

17 of a type of hashing function. The particular hashing function employed preferably 
1 8 . maximizes the uniqueness of the resulting fingerprint. 

19 At step 86, the customer computer clock 32 is queried for a current time value. At 

2 0 step 88, the fingerprint, the transaction ID, and the time value are communicated to the 



- 0 



18 



'WO 01/97134 PCT/US01/18076 



MDAS web ate 16 along with an HTTP header with cookie and "apparent" IP address, all 
of which are stored as 4 machine data profile 1.8 within the MDAS archive 17. 

At step 90, the MDC script adds a proxy piercer request to the transaction form 
which, when executed by the browser 28 at step 92, sends a request for a proxy piercer 
applet or code to the MDAS web site 16. When the proxy piercer applet/code is executed 
by the browser 28 at 94, a time value from the clock 32 is again queried at 96 and any 
existing local area network (LAN) address is queried at 98. At step 100, the proxy piercer 
applet/code sends the time value, the LAN address (if any), and the transaction ID to the 
MDAS web site 16 by a protocol which bypasses any existing HTTP proxy 26. The 
protocol used is one which is at a lower level than HTTP, such as UDP (user datagram 
protocol) or, preferably, TCP/IP (transmission control protocol/internet protocol). 

Bypassing tfie HTTP proxy 26 causes the data sent in step 100 to arrive at the 
MDAS web site 16 with the IP address of the primary gateway 22, which may be different 
from any apparent IP address previously recorded if an HTTP proxy 26 intervenes. If the 
proxy piercer procedure 82 is successful, the primary gateway IP address is stored at step 
102 within the machine data profile 18 identified by the transaction ID. It should be noted 
that some types of proxies, such lis some types of firewalls, may block all non-HTTP 
protocol packets, so that the proxy piercer procedure 82 might not be successful in all 
cases. 
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1 If the customer completes the transaction with the merchant web site 3, the 

2 transaction form is submitted at step 104, which causes the transaction record 6, including 

3 the transaction ID, to be stored at step 106 in the merchant database 7 for processing. 

4 Following are examples of code for an MDC script, as from steps 40 or 62. 

5 Assuming the machine data archiving service or MDAS web site 16 has the fictional URL 

6 (uniform resource locator) example-url.net and a specific merchant has a merchant 

7 identifier MMM, a line of HTML code is added at step 40 to the transaction foim of 

8 merchant MMM between the <form> and </form> HTML tags which has the form: 
9 

1 0 <script src=https://www. example-url.net/s/7MMMX/script> 
11 

1 2 When the customer browser 28 processes the transaction form at step 42, it 

- 13 requests a script file from the source URL: https://www.example-url net/s/?MMM 

14 At step 44, the customer web browser 28 requests the MDC script by way of the 

« 

1 5 HTTP protocol. The HTTP request includes the merchant ID MMM, the user agent 

1 6 (browser version), the IP address of the customer's HTTP proxy, and any HTTP cookies 

1 7 I previously sent to the customer by www.example-url.net Upon receiving this 

1 8 information, the archive service 16 records this information in a machine data record 

1 9 which also includes the transaction ID. 

2 0 Upon receiving the file request, the archive service 16 generates a unique 

2 1 transaction ID (represented below as ZZZ) at step 46 to be associated with the transaction 

20 
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1 and the machine parameter set. An exemplary transaction ID is a string of 24 letters and 

■ 

2 digits. The first eight digits form a time stamp which is a hexadecimal representation of 

3 the seconds elapsed since midnight January 1, 1970 UTC (coordinated universal time). 

4 In the preferred embodiment of the process 1, the MDC script is written in an 

5 ECMAScript compliant language, such as JavaScript, JScript, or VBScript. A JavaScript 

6 version of the MDC script is as follows (hnebreaks and indentations added for clarity): 



8 



document. write("<input name=transactionid type=hidden value=ZZZ>; 



10 



d=new DateQ; 



11 



12 



13 



t=3600*d.getHoureO^O*d.getMmutesO+d.getSecondsO; 



14 



15 



document.write("<img height=l width=l src=https://www.example- 
url.net/t/?i=ZZZ&t= M -K+">"); 



17 



18 



document.write( B <applet heights width=l 
codebase=https://www.example-url.net/ 



19 



code=a/?ZZZ> 



20 



21 



<param name=i value=ZZZx/applet>"); 
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1 The exemplary MDC script includes the unique transaction ID value in several 

2 places. When the script executes on the customer computer 20, it writes HTML code into 

3 the merchant's order form. Specifically: 

* 

4 1) The script adds a hidden variable called "transactionid" to the merchant's 

5 transaction form and assigns it the value of the transaction ID (277) when the 

6 transaction form is submitted, the merchant receives the transaction ID and can associate 

7 it with the transaction data record. 

8 2) The script computes the seconds elapsed since midnight on the clock 32 

9 and writes a request for a 1 pixel by 1 pixel image. Included in the request is the 

1 0 transaction ID and the time value. When the request executes, this data is sent back to the 

1 1 archive service 16 and recorded with the transaction ID in the MDAS archive 17. 

12 3 ) The script adds a request for a program located at the archive service web 

-T — 

13 site 16 which, in this example, is a Java applet The applet downloads to the customer 

1 4 computer 20 from the archive service 16 and executes, appearing as a 1 pixel by 1 pixel 

1 5 image on the transaction form. The transaction ID is passed to the program as a 

1 6 parameter specified in the script. The program performs three tasks: 

17 a) it calculates TTT, the seconds elapsed since midnight on the system clock 

18 32; 

19 b) it calculates AAA, the address of the customer 20 on its own local area 

20 network 24; and 
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c) it sends this data back to the archive service 16 via TCP/IP, by requesting 
the following URL: 

http://ww.example-url.net/d/?i=ZZZ&t=TTT&a ; =AAA 
The archive service 16 receives the message which includes the parameters TTT, 
AAA, and ZZZ. The message also includes the IP address of the sender. This address is 
the customer's actual IP address, which in some cases is different from the HTTP proxy IP 
address. The archive service 16 records this information in the MDAS archive 17 and 
associates it with the transaction ID ZZZ. 

The machine data collection and archiving process 1 of the present invention has 
been described with a particular application in fraud detection. However, it is foreseen 
that the techniques of the present invention have a wider application, as for marketing or 
computer support purposes, or other functions. While the process 1 has been described 

i — 

with reference to the internet 4 or world wide web, it is also conceivable that the process 1 
could be employed on computer networks of less than global expanse, such as a large 
intranet, a national or regional network, or the like. 

Therefore, it is to be understood that while certain forms of the present invention 
have been illustrated and described herein, the present invention is not intended to be 
limited to the specific forms, arrangement of parts, sequence of steps, or particular 
applications described and shown. 
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k 

CLAIMS 

What is claimed and desired to secure by Letters Patent is: 
A process for collecting machine identifying information associated with a digital 
online access device used for substantially anonymously accessing a host computer 
system over a digital network, said host computer system generating an interaction 
record of an access therewith by said access device, and said process comprising 

m 

the steps of: 

(a) capturing a machine identifying profile parameter upon said access device 
accessing said host computer system; 

♦ 

(b) generating a unique interaction identification string upon said access device 
accessing said host computer system; 

(c) associating said interaction identification string with said profile parameter; 
and 

(d) associating said interaction identification string with said interaction record 
generated upon said access device accessing said host computer system. 

A process as set forth in Claim 1 wherein said capturing step includes the step of: 
(a) capturing a digital address of said access device on said digital network. 

A process as set forth in Claim 1 wherein said capturing step includes the step of: 
(a) capturing a configuration setting of said access device. 

24 
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A process as set forth in Claim 1 and including the steps of: 

(a) communicating a self-identification routine to said access device upon said 
access device accessing said host computer system; 

(b) said access device executing said self-identification routine; 

(c) said self-identification routine, querying a configuration setting of said 
access device to derive said profile parameter, and 

m 

(d) said self-identification routine communicating said profile parameter to a 
remote location for association with said interaction identification string. 

A process as set forth in Claim 1 and including the steps of: 

(a) said host system operating a host web site including an interaction page 
generated by interaction p_age code processed by said access device upon 
accessing said host web site; and - 

(b) coding, within said interaction page code, a self-identification routine 
which causes said access device to communicate said profile parameter 
when said access device processes said interaction page code. 

A process as set forth in Claim 3 and including the Step .of: 
(a) coding said self-identification routine in such a manner that said profile 
parameter and said interaction identification string are communicated to a 
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third party web site at which said profile parameter and said interaction 
identification string are stored. . 



7. A process for identifying a customer computer involved in an online transaction 
between a customer using a customer browser operating on said customer 
computer and a merchant operating a merchant web site, said method comprising 
the steps of: 

(a) capturing a customer computer profile parameter upon said customer 
computer accessing said merchant web site; 

(b) generating a transaction identification string and associating said string 
with said parameter; 

. (c) storing said parameter and said string in a machine data archive* 

(d) - upon said customer completing a transaction through said merchant web 
site, storing said transaction identification string with a transaction record 
formed during said transaction to thereby associate said parameter with 
said transaction record through said string. 



8. A process as set forth in Claim 7 wherein said capturing step includes the step of: 
(a) capturing an IP address of said customer computer. 
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9. A process as set forth in Claim 7 wherein said capturing step includes the step of: 
(a) capturing a configuration setting of said customer computer. 

10. A process as set forth in Claim 7 and including the step of 

(a) communicating said profile parameter and said transaction identification 

i 

string to a third party web site for storage. 

11. A process as set forth in Claim 7 and including the step of: 

(a) causing said customer computer to communicate said profile parameter and 
said transaction identification string to a third party web site for storage. 

12. A process as set forth in Claim 7 and including the steps of: 

(a) communicating a self-identification routine to said customer computer 
upon said customer computer accessing said merchant web site; 

(b) said customer computer executing said self-identification routine; 

(c) said self-identification routine querying a configuration setting of said 
customer computer to derive said profile parameter; and 

(d) said self-identification routine communicatirig said profile parameter to a 
remote location for association with said interaction identification string. 
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13 . A process as set forth in Claim 12 and including the step of: 

r 

(a) coding said self-identification routine in such a manner that said profile 

* 

parameter and said interaction identification string are communicated to a 
third party web site at which said profile parameter and said interaction 
identification string are stored. 

0 

14. A process as set forth in Claim 12 wherein said querying step includes the steps of: 

(a) querying said customer browser for a plurality of configuration settings; 

(b) forming an attribute string from said plurality of configuration settings; and 

♦ 

(c) processing said attribute string to form said profile parameter of said 
customer computer. 

-r _ 

15. A process as set forth in Claim 12 wherein said customer computer potentially 
accesses said merchant web site by way of a proxy, and said communicating step 
includes the steps of: 

(a) communicating said profile parameter and said transaction identification 
string to said remote web site using a protocol which bypasses said proxy. 

16. A process for identifying a customer computer involved in an online transaction 
through a merchant web site between a customer using a customer browser 
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operating on said customer computer and a merchant who operates said web site, 
said method comprising the steps of: 

(a) coding a script request within a transaction form of said merchant web site; 

(b) processing said script request by said customer browser upon accessing 
said merchant web site to thereby communicate to an archiver web site of a 
machine data archiving service an electronic request for a machine data 
collection script; 

(c) said archiver web site returning said script to said customer browser along 
with a unique transaction identification string; 

(d) said customer browser processing said script to thereby cause said script to 
query said customer computer for a profile parameter of said customer 
computer; 

■i 

(e) said script causing said customer browser to communicate said profile 
parameter and said transaction identification string to said archiver web 
site; 

(f) said archiver web site storing said profile parameter and said transaction 
identification string in a machine data profile; 

(g) said script causing said customer browser to write said transaction 
identification string into said transaction form; and 

(h) upon said customer adding customer identification information to said 
transaction form and electronically submitting said transaction form to said 
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merchant web site to thereby comprise a transaction record, said 
transaction identification- string associating said transaction record with said 
machine data profile. 

A process as set forth in Claim 16 and including the steps of: 

(a) said script causing said computer browser to communicate said profile 
parameter and said transaction identification string along with a 
conventional hypertext transfer protocol (HTTP) header, and 

(b) said archiver service additionally storing said HTTP header in association 
with said machine data profile. 

A process as set forth in Claim 16 and including the step of: 

(a) said script querying said customer browser for a configuration setting 
thereof 

A process as set forth in Claim 16 and including the steps of: 

(a) said script querying said customer browser for a plurality of configuration 
settings; 

(b) said script forming an attribute string from said plurality of configuration 
settings; and 
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(c) said script processing said attribute string to form said profile parameter of 
said customer computer. 



20. A process as set forth in Claim 19 wherein said script processing step includes the 
step of: 

» 

(a) said script performing a hashing function on said attribute string to form 
said profile parameter. 



21. A process as set forth in Claim 16 wherein said customer computer potentially 
accesses said merchant web site by way of a proxy, and including the step of: 
(a) said script communicating said profile parameter and said transaction 

identification string to said archiver service web site using a , protocol which 
bypasses said proxy. 



22. A process as set forth in Claim 16 and including the step of: 

(a) said script communicating said profile parameter to said archiver service 
web site using a protocol other than HTTP. 



23 . A process as set forth in Claim 16 wherein said customer computer includes a 
digital clock, and including the steps of: 
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(a) said script causing said customer browser to query said clock for a time 
value; and 

* 

(b) said script causing said customer browser to send said time value to said 
archiver service web site along with said profile parameter. 

A process for identifying a customer computer involved in an online transaction 
through a merchant web site between a customer using a customer browser 
operating on said customer computer and a merchant who operates said web site, 
said method comprising the steps of: 

(a) coding a script request within a transafetion form of said merchant web site; 

(b) processing said script request by said customer browser upon accessing 
said merchant web site to thereby communicate to an archiver web site of a 
machine data archiving service an electronic request for a machine data 
collection script; 

(c) said archiver web site returning said script to said customer browser along 
with a unique transaction identification string; 

(d) said customer browser processing said script to thereby cause said script 
to: 

(1) query said customer browser for a plurality of configuration 
settings; 

(2) form an attribute string from said plurality of configuration settings; 
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(3) perform a hashing function on said attribute string to form said 
profile parameter; and - 

(4) query an internal digital clock of said customer computer for a 
current time value; 

(e) said script causing said customer browser to communicate said profile 
parameter, said time value, and said transaction identification string to said 
archiver web site along with a conventional HTTP header; 

4 

(f) said archiver web site storing said profile parameter, said time value, and 
said transaction identification string in a machine data profile; 

(g) said script causing said customer browser to write said transaction 

► 

identification string into said transaction form; and 

* 

(h) upon said customer adding customer identification information to said 

* 

transaction form and electronically submitting said transaction form to said 
merchant web site to thereby comprise a transaction record, said 
transaction identification string associating said transaction record with said 
machine data profile. 



A process as set forth in Claim 24 wherein said customer computer potentially 
accesses said merchant web site by way of a proxy, and including the steps of: 
(a) said script querying said customer computer for a second profile parameter; 
and 
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(b) said script communicating said second profile parameter and said 

* 

transaction identification string to said archiver service web she using a 

» *. 

protocol which bypasses said proxy. 

A process as set forth in Claim 25 and including the step of: 
(a) said script communicating said second profile parameter to said archiver 
service web site using a protocol other than HTTP. 
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